查看原文
其他

gpreftools动态追踪Nginx进行性能分析

运维研习社 运维研习社 2022-11-05


之前介绍了多种nginx调试工具,今天介绍nginx性能分析工具——gperftools


gperftools是google_perftools,google开发的一款非常使用的工具集,主要包括性能优异的malloc free内存分配器tcmalloc、基于tcmalloc的堆内存检测和内存泄露分析工具heap-profiler、heap-checker、基于tcmalloc实现的程序CPU性能检测工具cpu-profiler


github上提供了非常详尽的文档https://github.com/gperftools/gperftools


回到主题,在nginx中,可以通过--with-google_perftools_module编译参数启用这个性能分析模块

如图,添加编译参数,重新编译nginx


该模块依赖于gpreftools库,所以在编译之前,需要先编译安装gperftools,在64位系统下,需要先安装libunwind


libunwind安装:

从https://github.com/libunwind/libunwind/releases或http://download.savannah.gnu.org/releases/libunwind/下载最新版本安装包

解压,编译安装

当然,你也可以--prefix指定位置编译安装


安装完成后,安装gperftools


安装完成后,重新编译安装nginx


编译安装完后,如果遇到找不到lib共享库,可以和上图一样,做软链处理,libunwind和gperftools编译完成后,共享库都是存储在/usr/local/lib的,而64位的系统中通常是找/lib64下面的,或者可以通过添加ldconfig来解决


解决上诉问题后,可以看到nginx已经开启了google_perftools模块


在nginx中配置gperftools很简单,就一个指令

配置在主配置文件中,指定分析信息存储的文件位置及名称即可


这样就会生成一个分析结果文件,后面的数字是nginx工作进程的PID号


接着用ab压测一下nginx,接着再重载一下nginx,让分析结果落盘写入分析信息文件


生成的文件不方便查看,所以我们通过svg来查看,首先安装图像分析生成工具graphviz,直接通过yum安装就可以


安装完成后,通过pprof来生成svg

生成nginx.svg,我们查看结果,为了方便完整,我转换成了png


这样我们就能很清晰的看到nginx的调用和性能消耗,从而找到性能瓶颈点,进行相应优化


Nginx通过split_client实现客户端分流 利用Nginx流量镜像,优雅接入waf Nginx执行阶段详解 



更多精彩内容请扫描下方二维码关注公众号


扫描二维码关注我们吧



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存